<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>具名插槽</title>
</head>

<body>
  <div id="app">
    <com1>

      <template slot="header">
        <p>头部区域</p>
        <p>导航区域</p>
      </template>


      <p>内容1</p>
      <p>内容2</p>
      <p slot="footer">页脚区域</p>
    </com1>
  </div>
  <script src="./js/vue.js"></script>
  <script>

    Vue.component('com1', {
      data: function () {
        return {
          name: 'zhangsan'
        }
      },

      // 具名插槽，就是具有名字的插槽，给slot标签添加一个name属性
      // 将组件标签中包裹的内容展示到指定的 slot 位置
      template: `
        <div>
          <header>
            <slot name='header'></slot>  
          </header>
          <main>
            <slot></slot>
          </main>
          <footer>
            <slot name='footer'></slot>
          </footer>
        </div>
      `
    })
    var vm = new Vue({
      el: '#app',
      data: {}
    })
  </script>
</body>

</html>